package com.pn.taikao.mapper;

import com.pn.taikao.entity.PaperStudent;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface PaperStudentMapper {
    /**
     * 插入试卷学生发布关系
     */
    int insert(PaperStudent paperStudent);
    
    /**
     * 批量插入试卷学生发布关系
     */
    int insertBatch(@Param("list") List<PaperStudent> list);
    
    /**
     * 根据试卷ID删除所有发布关系
     */
    int deleteByPaperId(@Param("paperId") Long paperId);
    
    /**
     * 根据试卷ID和学生ID删除发布关系
     */
    int deleteByPaperIdAndStudentId(@Param("paperId") Long paperId, @Param("studentId") Long studentId);
    
    /**
     * 根据试卷ID查询所有发布关系
     */
    List<PaperStudent> selectByPaperId(@Param("paperId") Long paperId);
    
    /**
     * 根据学生ID查询所有发布关系
     */
    List<PaperStudent> selectByStudentId(@Param("studentId") Long studentId);
    
    /**
     * 根据试卷ID和学生ID查询发布关系
     */
    PaperStudent selectByPaperIdAndStudentId(@Param("paperId") Long paperId, @Param("studentId") Long studentId);
    
    /**
     * 检查试卷是否发布给指定学生
     */
    boolean existsByPaperIdAndStudentId(@Param("paperId") Long paperId, @Param("studentId") Long studentId);
}


